草庐IT

带指针的 C++ vector

全部标签

c++ - 在构造函数中引用此指针

Followingisanotherexampleofforwarddeclaration,whichmightbeusefuliftheapplicationneedsaself-sustainingarrayofobjectswhichisabletoaddandremoveobjectsfromitselfduringrun-time:Filea.h:classA{public:staticA*first,*last;A*previous,*next;A();~A();};Filea.cpp:#include"a.h"A*A::first=0,*A::last=0;//don't

c++ - 指向 C++ 类元素的指针

我有一个C++类c_image,它包含指向c_pixel类元素的指针vector:classc_image{public:vector>pixel;...};c_pixel类元素包含一个double类型的元素Z:classc_pixel{public:doubleZ;...};但是,它们使用c_pixel_pv类进行扩展,其中包含pv,一个包含三个double类型元素的数组:classc_pixel_pv:publicc_pixel{public:doublepv[3];...};类c_image还有一个函数filtervectorc_image::filter(???){...};它

c++ - protected 成员不能通过指针或对象访问

我有2个类Training和Testing,其中Training是基类,Testing是派生类训练类。我有Testing类成员函数,floattotalProb(Training&classProb,Training&total),它有2个参数,都是Training类对象。代码:voidTesting::totalProb(Training&classProb,Training&total){_prob=(_prob*((float)(classProb._nOfClass)/total._tnClass));coutfirst基本上这个函数所做的是计算test1(Testing类的一

c++ - vector 的 vector 作为高效的数据结构; std::vector<std::vector<someType>> 的替代品

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭6年前。Improvethisquestion我正在寻找可以在一个vector中存储多个vector而不会出现碎片或任何性能问题的数据结构。现在做这个std::vector>myMultiVector;会有所帮助,但据我所知,内存会变得碎片化,因为myMultiVector中的每个vector显然不会位于连续空间中,因为它的分配方案。这不适用于创建我从一开始就知道维度或大小的数组。各个方向的尺寸都是动态的。我想要的是那种结构,其中分配的大小是连续的。

c++ - 如何将流cin加载到 vector 中

我想从cin加载一个包含整数的vector。以下代码有效:std::istream_iteratoriterBegin(std::cin),iterEnd;vectorv(iterBegin,iterEnd);但是,当我尝试更简洁地编写它时,它失败了:vectorv(std::istream_iterator(std::cin),std::istream_iterator());有什么想法吗? 最佳答案 正如IgorTandetnik所指出的,您遇到了C++最令人烦恼的解析。解决方案(如果您的编译器理解C++11)是使用统一的初始化

C++11 对模板参数类型的 vector 使用迭代器

这个问题在这里已经有了答案:WhereandwhydoIhavetoputthe"template"and"typename"keywords?(8个答案)关闭6年前。我有一个模板类,其中包含作为模板参数给出的类型的指针vector。我希望能够使用基于范围的迭代来迭代vector的有限部分。我的类包含以下功能:templateclassObjectList{...public://!Beginiterationoveralistofobjectsstd::vector::iteratorbegin();//!Iteratortoonepasttheendofthelistofobjec

c++ - 创建线程并让 "this"指针从构造函数中逃逸总是安全的吗?

我对以下代码感到困惑(来自PreferUsingActiveObjectsInsteadofNakedThreads):classActive{public:classMessage{//baseofallmessagetypespublic:virtual~Message(){}virtualvoidExecute(){}};private://(suppresscopyingifinC++)//privatedataunique_ptrdone;//lesentinelmessage_queue>mq;//lequeueunique_ptrthd;//lethreadprivate

C++ Std 队列和 vector 性能

我最近一直在处理图形,我正在研究从图形返回路径。该路径需要作为包含所有节点的标准vector返回,其中起始节点在前。我一直在寻找两种选择:-使用slowvectorinsert方法在vector前面添加节点-使用双端队列将节点添加到前端(push_front),这样速度更快。然后使用std::copy将双端队列复制到vector与另一种方法相比,使用一种方法是否有显着的性能提升? 最佳答案 由于您要返回一条路径,因此您可能对其长度有一个上限。因此,您可以调用创建一个vector,调用reserve之后(如@user2079303所写

C++ - 高效计算 vector 矩阵乘积

我需要尽可能高效地计算乘积vector矩阵。具体来说,给定一个vectors和一个矩阵A,我需要计算s*A。我有一个Vector类,它包装了一个std::vector和一个Matrix类,它也包装了一个std::vector(为了效率)。天真的方法(我现在正在使用的方法)是有类似的东西VectortimesMatrix(Matrix&matrix){Vectorresult(matrix.columns());//constructorthatdoesaresizeontheunderlyingstd::vectorfor(unsignedinti=0;i它工作正常,耗时将近12000

c++ - 共享指针的双重检查锁定

免责声明:我有Java背景,因此,我不知道C++(和相关库)的许多内部机制是如何工作的。我已经阅读了足够多的资料,知道双重检查锁定是邪恶的,正确和安全地实现单例模式需要适当的工具。我认为以下代码可能不安全,受编译器重新排序和未初始化对象分配的影响,但我不确定我是否遗漏了一些我不了解该语言的内容。typedefboost::shared_ptrAPtr;APtrg_a;boost::mutexg_a_mutex;constAPtr&A::instance(){if(!g_a){boost::mutex::scoped_locklock(g_a_mutex);if(!g_a){g_a=bo